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Amendments To the Claims 



Kindly replace the claims as follows. 



1 1. (currently amended) The computer, comprising: 

2 a multi-stage execution pipeline; 

3 an instruction decoder designed: 

4 to decode instructions of a complex instruction set for execution by the 

5 pipeline, the instruction set being architecturally exposed for execution by user-state 

6 programs stored in a main memory of the computer, the instruction set having variable-length 

7 instructions and many instructions having multiple side-effects and a potential to raise 

8 multiple exceptions, 

9 for at least some instructions of the complex instruction set, to issue two or 

10 more instructions in a second internal form into the execution pipeline; 

1 1 to generate information descriptive of instructions to be executed by the 

12 pipeline, and to store the information into non-pipelined processor registers of the computer; 

13 to determine whether instructions will complete in the pipeline, and to abstain 

14 from writing descriptive information into the processor registers for instructions following an 

15 instruction determined not to complete; 

16 the pipeline being designed to recognize an exception occurring in an instruction after 

17 an earlier a first side-effect of the instruction has been architecturally committed and before a 

18 later side of the instruction is architecturally committed , and thereupon, to architecturally 

19 expose in the processor registers information describing a processor state of the computer, 

20 including an intra-instruction program counter value, and to transfer execution to an 

21 exception handler; and 

22 pipeline resumption circuitry effective after completion of the software exception 

23 handler to resume execution of the excepted program based on the information in the 

24 processor registers; 
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25 the processor registers of the computer being designed to architecturally expose 

26 sufficient information about the state of the excepted instruction that the transfer and resume 

27 are effected without saving processor state to the main memory. 

1 2. (original) The method, comprising the steps of: 

2 decoding and executing instructions of a complex instruction set of a computer, the 

3 instruction set having variable-length instructions and many instructions having multiple 

4 side-effects; 

5 storing information describing the decoding of the complex instructions into 

6 architecturally- visible processor registers of the computer. 

3. (currently amended) The method of claim 2, further comprising the step of: 
recognizing an exception occurring in an instruction after an earlier a first side-effect 

of an instruction has been architecturally committed and before a later side of the instruction 
is architecturally committed ; 

transferring control to a software exception handler for the fest exception; 

resuming execution of the excepted instruction after completion of the exception 
handler, the architecturally-visible processor registers exposing sufficient information that 
the transfer and resumption are effected without saving the full state of the excepted 
instruction on a memory stack. 

4. (original) The method of claim 2: 

wherein the instructions are executed in a multi-stage execution pipeline, and the 
architecturally- visible processor registers are not pipelined; 
and further comprising the steps of: 

determining whether instructions will complete in the pipeline; and 
abstaining from writing descriptive information into the architecturally-visible 
processor registers for instructions following an instruction determined not to complete. 
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5. (currently amended) The method of claim 2, further comprising the steps of: 
on recognizing an exception occurring in an instruction after an earlier a first side- 
effect of an instruction has been architecturally committed and before a later side of the 
instruction is architecturally committed , architecturally exposing an instruction pointer, 
contents of a general register file, and contents of processor registers to a software exception 
handler, the processor registers and general purpose registers of the computer architecturally 
exposing sufficient processor state and providing sufficient working storage for execution of 
a software exception handler and resumption of the program, without recomputing the earlier 
fest side-effect, and without storing processor state to the main memory. 

6. (original) The method of claim 5, further comprising the step of: 
abstaining the storing during execution of the software exception handler. 

7. (original) The method of claim 2, wherein: 

wherein the complex instructions are fetched in an external form from a memory; 
and further comprising the steps of: 

for at least some external-form instructions, decoding each instruction into 
two or more instructions into an internal form for execution in an execution pipeline; 

capturing and architecturally exposing an intra-instruction program counter 
value into the architecturally- visible processor register when a complex instruction raises an 
exception at an intermediate point. 

8. (original) The computer, comprising: 

an instruction decoder and pipeline designed to decode and execute instructions of a 
complex instruction set having variable-length instructions and many instructions having 
multiple side-effects; 
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processor register control circuitry designed to store information describing the 
decoding of the complex instructions into architecturally-visible processor registers of the 
computer. 

9. (original) The computer of claim 8, further comprising: 

a collection of software exception handlers, the processor register circuitry designed 
to abstain from storing information into the processor registers during execution of at least 
some of the software exception handlers. 

10. (original) The computer of claim 8, wherein the decoding information presents 
information about the instructions of the complex instruction set in a form uniform across 
most of the complex instruction set. 

11. (original) The computer of claim 8, further comprising a mask register of bits, 
each bit corresponding to a class of instructions of the instruction set, a value of each bit 
designating whether to raise an exception on execution of an instruction of the corresponding 
class. 

12. (original) The computer of claim 8, wherein the architecturally-visible processor 
registers are not architecturally- visible in the complex instruction set, but are architecturally- 
visible in an alternative instruction set of the computer, the alternative instruction set being 
architecturally available to user-state programs. 

13. (original) The computer of claim 8, wherein the decoding information includes a 
designation of any prefix to the current instruction. 

14. (original) The computer of claim 8, wherein the decoding information includes a 
designation of an operand effective address. 
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15. (original) The computer of claim 8, wherein the decoding information includes a 
sign-extended value of an immediate value. 

16. (original) The computer of claim 8, wherein the decoding information includes a 
designation of a length of the currently-executing instruction. 

17. (original) The computer of claim 8, wherein the decoding information includes a 
designation of a current instruction pointer and an instruction pointer to a next instruction. 

18. (original) The computer of claim 8, wherein the decoding information includes 
an instruction pointer value and an indication of an intra-instruction fractional completion of 
the complex instructions. 

19. (original) The computer of claim 8, wherein the decoding information includes 
an instruction pointer value and an indication of a protection mode of the computer. 

20. (currently amended) The computer of claim 8, further comprising: 
pipeline control circuitry designed to recognize an exception occurring in an 

instruction after an earlier a-fest side-effect of the instruction has been architecturally 
committed and before a later side of the instruction is architecturally committed , to transfer 
control to a software exception handler for the fost exception, and to resume execution of the 
excepted instruction after completion of the exception handler, processor registers of the 
computer being designed to architecturally expose sufficient information about the state of 
the excepted instruction that the transfer and resume are effected without saving intermediate 
results of the excepted instruction on a memory stack. 
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1 21. (currently amended) The method, comprising the steps of: 

2 executing a program in user state of a computer, the program coded in an instruction 

3 set having many instructions with multiple side-effects and the potential to raise multiple 

4 exceptions; 

5 in response to recognizing an exception occurring in an instruction after an earlier a 

6 fest side-effect of the instruction has been architecturally committed and before a later side- 

7 effect of the instruction is architecturally committed , transferring control to a software 

8 exception handler for the fest exception, and resuming execution of the excepted instruction 

9 after completion of the exception handler, processor registers of the computer being designed 

10 to architecturally expose sufficient information about the intermediate state of the excepted 

1 1 instruction that the transfer and resume are effected without saving intermediate results of the 

12 excepted instruction on a memory stack. 

22. (original) The method of claim 21, further comprising the steps of: 
wherein the instructions are executed in a multi-stage execution pipeline, and the 

processor registers are not pipelined; 

and further comprising the steps of: 

at an early stage of the pipeline, determining whether instructions will 
complete in the pipeline; and 

abstaining from writing descriptive information into the architecturally-visible 
processor registers for instructions following an instruction determined not to complete. 

23. (currently amended) The method of claim 21, further comprising the steps of: 
on recognizing the exception, architecturally exposing an instruction pointer, contents 

of a general register file, and contents of processor registers to a software exception handler, 
the processor registers and general purpose registers of the computer architecturally exposing 
sufficient processor state and providing sufficient working storage for execution of a 



Response to Office Action 

This paper dated October 1 8, 2004 



7 1 14596-27-0052BS S/N 09/667,226 

2646125.1 



Application Serial No. 09/667,226 
Attorney Docket No. 1 14596-27-0052BS 

Amendment Dated October 18, 2004 - Response to Office Action of June 17, 2004 

software exception handler and resumption of the program, without recomputing the earlier 
first side-effect, and without storing processor state to the main memory. 

24. (currently amended) The method of claim 21, further comprising the steps of: 
in response to recognizing an exception occurring in an instruction after the earlier a 
first side-effect of the instruction has been architecturally committed, architecturally 
exposing an intra-instruction program counter value in the processor registers. 

1 25. (currently amended) The computer, comprising: 

2 an instruction decoder for an instruction set exposed for execution by user-state 

3 programs, many individual instructions of the instruction set having multiple side-effects and 

4 a potential to raise multiple exceptions; 

5 pipeline control circuitry designed to recognize an exception occurring in an 

6 instruction after an earlier a first side-effect of the instruction has been architecturally 

7 committed and before a later side-effect of the instruction is architecturally committed , to 

8 transfer control to a software exception handler for the earlier fifst exception, and to resume 

9 execution of the excepted instruction after completion of the exception handler, processor 

10 registers of the computer being designed to architecturally expose sufficient information 

1 1 about the state of the excepted instruction that the transfer and resume are effected without 

12 saving intermediate results of the excepted instruction on a memory stack. 

26. (original) The computer of claim 25, further comprising: 

processor register control circuitry designed to store information describing decoding 
of sequential instructions decoded by the decoder into the processor registers of the 
computer. 

27. (original) The computer of claim 25, wherein the processor registers are not 
architecturally-visible in the multiple side-effect instruction set, but are architecturally-visible 
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in an alternative instruction set of the computer, the alternative instruction set being 
architecturally available to user-state programs. 

28. (original) The computer of claim 25, wherein the pipeline control circuitry is 
further designed to abstain from the altering the contents of the processor registers during 
execution of the exception handler. 

29. (original) The computer of claim 25, wherein the decoding information includes 
a designation of a base register and offset of an operand effective address. 

30. (original) The computer of claim 25, wherein the decoding information includes 
a designation of a current instruction pointer and an instruction pointer to a next instruction. 

31. (original) The computer of claim 25, wherein the decoding information includes 
an instruction pointer value and an indication of an intra-instruction fractional completion of 
the complex instructions. 

32. (original) The computer of claim 31, wherein the an indication of an intra- 
instruction fractional completion includes a designation of a repeat prefix to the current 
instruction. 

33. (original) The computer of claim 25, wherein the operation of the exception 
handler is controlled at least in part by the contents of the processor registers. 

34. (original) The computer of claim 25, wherein intermediate results of the multiple 
side-effect instructions are stored in general purpose registers of the computer. 
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1 35. (original) The method, comprising the step of: 

2 while decoding a sequence of computer instructions for execution in a multi-stage 

3 execution pipeline and before commencing substantial execution of each decoded instruction 

4 of the sequence, generating information descriptive of the instruction, and, depending on a 

5 determination of whether the instruction will complete in the pipeline, storing or abstaining 

6 from storing the generated information into a non-pipelined register of the computer. 

36. (currently amended) The method of claim 35: 

on recognizing an exception occurring in an instruction after an earlier a first side- 
effect of the instruction has been architecturally committed and before a later side of the 
instruction is architecturally committed , architecturally exposing an instruction pointer, 
contents of a general register file, and contents of processor registers to a software exception 
handler, the processor registers and general purpose registers of the computer architecturally 
exposing sufficient processor state and providing sufficient working storage for execution of 
a software exception handler and resumption of the program, without recomputing the earlier 
fest side-effect, and without storing processor state to the main memory. 

37. (original) The method of claim 35: 

for at least some of the decoded instructions, issuing two or more instructions in a 
second instruction set into the pipeline; 

for at least some of the decoded instructions, capturing and architecturally exposing 
an intra-instruction program counter value when the decoded instruction raises an exception 
at an intermediate point. 
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1 38. (original) The computer, comprising: 

2 a multi-stage execution pipeline; 

3 an instruction decoder designed to generate information descriptive of instructions to 

4 be executed by the pipeline, and to store the information into a non-pipelined register of the 

5 computer; 

6 the instruction decoder being designed to determine whether instructions will 

7 complete in the pipeline, and to abstain from writing descriptive information into the register 

8 for instructions following an instruction determined not to complete. 

39. (original) The computer of claim 38, wherein the instruction decoder and 
pipeline are designed to decode and execute instructions of a complex instruction set having 
variable-length instructions and many instructions having multiple side-effects. 

40. (original) The computer of claim 39, wherein the descriptive information 
describes the decoding of the complex instructions. 

41. (currently amended) The computer of claim 38, further comprising: 

pipeline control circuitry designed to recognize an exception occurring in an instruction after 
an earlier a first side-effect of the instruction has been architecturally committed and before a 
later side of the instruction is architecturally committed , to transfer control to a software 
exception handler for the fost exception, and to resume execution of the excepted instruction 
after completion of the exception handler, processor registers of the computer being designed 
to capture sufficient information about the state of the excepted instruction that the transfer 
and resume are effected without saving intermediate results of the excepted instruction on a 
memory stack. 



Response to Office Action 

This paper dated October 1 8, 2004 



1 1 1 14596-27-0052BS S/N 09/667,226 

2646125.1 



Application Serial No. 09/667,226 
Attorney Docket No. 1 14596-27-0052BS 

Amendment Dated October 18, 2004 - Response to Office Action of June 17, 2004 

42. (original) The computer of claim 38, wherein the execution pipeline and 
instruction decoder are designed to retire instructions individually and independently, with at 
most a few interactions between instructions to affect retirement. 

43. (original) The computer of claim 38, wherein: 

intermediate results of instructions decoded by the instruction decoder are stored in 
registers of a general register file that are not architecturally addressable in the instructions 
decoded by the instruction decoder. 

44. (original) The computer of claim 38, wherein the decoding information includes 
an instruction pointer value and an indication of an intra-instruction fractional completion of 
the complex instructions. 

45. (original) The computer of claim 38, further comprising a mask register of bits, 
each bit corresponding to a class of instructions of the instruction set, a value of each bit 
designating whether to raise an exception on execution of an instruction of the corresponding 
class. 

1 46. (original) The method, comprising the steps of: 

2 while executing a program coded in an instruction set exposed for execution by 

3 programs stored in a main memory of the computer, recognizing an exception occurring in a 

4 program, and in response, architecturally exposing in processor registers of the computer 

5 information describing a processor state of the computer and transferring execution to an 

6 exception handler; 

7 after completion of the software exception handler, resuming execution of the 

8 excepted program based on the information in the processor registers; 

9 the processor registers and general purpose registers of the computer architecturally 
10 exposing sufficient processor state and providing sufficient working storage for execution of 
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1 1 the exception handler and resumption of the program, without storing processor state to the 

12 main memory. 

47. (original) The method of claim 46, wherein the exception occurs at an 
intermediate point of an instruction, and the processor registers architecturally expose an 
intra-instruction program counter value. 

48. (original) The method of claim 46, wherein instructions of the exposed 
instruction set are managed by a memory management unit between a main memory of the 
computer and one or more cache levels. 



1 49. (original) The computer, comprising: 

2 an instruction decoder for an instruction set exposed for execution by programs stored 

3 in a main memory of the computer; 

4 pipeline exception circuitry, effective on recognizing an exception occurring in a 

5 stored program, to architecturally expose in processor registers of the computer information 

6 describing a processor state of the computer, and to transfer execution to an exception 

7 handler; and 

8 pipeline resumption circuitry effective after completion of the software exception 

9 handler to resume execution of the excepted program based on the information in the 

10 processor registers; 

1 1 the processor registers and general purpose registers of the computer architecturally 

12 exposing sufficient processor state and providing sufficient working storage for execution of 

13 the exception handler and resumption of the program, without storing processor state to the 

14 main memory. 
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50. (original) The computer of claim 49, wherein: 

the instruction set is a complex instruction set having variable-length instructions and 
many instructions having multiple side-effects and a potential to raise multiple exceptions. 

51. (original) The computer of claim 50, wherein: 

the processor registers are designed to describe the decoding of the complex 
instructions. 

52. (original) The computer of claim 49, wherein: 

the exception occurs at an intermediate point in the execution of an instruction; and 
the processor registers of the computer are designed to capture sufficient information 
about the state of an the excepted instruction that the transfer and resume are effected without 
saving intermediate results of the excepted instruction on a memory stack. 

53. (original) The computer of claim 49, wherein: 

an execution pipeline of the computer is arranged in a plurality of stages; 
the processor registers are not pipelined; and 

the instruction decoder is designed to determine whether instructions will complete in 
the pipeline, and to abstain from writing descriptive information into the processor registers 
for instructions following an instruction determined not to complete. 

54. (original) The computer of claim 49, wherein the execution pipeline and 
instruction decoder are designed to retire instructions individually and independently, with at 
most a few interactions between instructions to affect retirement. 
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55. (original) The computer of claim 49, wherein: 

intermediate results of instructions decoded by the instruction decoder are stored in 
registers of a general register file that are not architecturally addressable in the instruction set 
decoded by the instruction decoder. 

56. (original) The computer of claim 49, wherein the information stored in the 
processor registers includes a designation of a current instruction pointer and an instruction 
pointer to a next instruction. 

57. (original) The computer of claim 49, further comprising a mask register of bits, 
each bit corresponding to a class of instructions of the instruction set, a value of each bit 
designating whether to raise an exception on execution of an instruction of the corresponding 
class. 

58. (original) The computer of claim 49, being designed to preserve values of the 
processor registers during execution of the software exception handler. 

1 59. (original) The method, comprising the steps of: 

2 fetching instructions in a first external instruction set from a memory, and, for at least 

3 some instructions of the first instruction set, issuing two or more instructions in a second 

4 form into an execution pipeline; 

5 architecturally exposing an intra-instruction program counter value when an 

6 instruction of the first instruction set raises an exception at an intermediate point. 

60. (original) The method of claim 59, wherein a register exposing the intra- 
instruction program counter is not architecturally visible in the first instruction set, but is 
architecturally-visible in the second instruction set of the computer, the second instruction set 
being architecturally available to user-state programs. 
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1 61. (original) The computer, comprising: 

2 an instruction decoder and execution pipeline, the decoder designed to fetch 

3 instructions in a first instruction set from a memory, and, for at least some instructions of the 

4 first instruction set, to issue two or more instructions in a second internal form into the 

5 execution pipeline; 

6 a register and control logic for that register that capture and architecturally expose an 

7 intra-instruction program counter value when an instruction of the first instruction set raises 

8 an exception at an intermediate point. 

62. (original) The computer of claim 61 wherein the first instruction set is a complex 
instruction set having many instructions having multiple side-effects and the potential to raise 
multiple exceptions. 

63. (original) The computer of claim 62, further comprising: 

processor register control circuitry designed to store information describing the decoding 
of the complex instructions into architecturally- visible processor registers of the computer. 

64. (currently amended) The computer of claim 62, further comprising: 
pipeline control circuitry designed to recognize an exception occurring in a complex 

instruction after an earlier a-fesi side-effect of the complex instruction has been architecturally 
committed and before a later side of the instruction is architecturally committed , to transfer 
control to a software exception handler for the fest exception, and to resume execution of the 
excepted complex instruction after completion of the exception handler, processor registers of 
the computer being designed to architecturally expose sufficient information about the state of 
the excepted complex instruction that the transfer and resume are effected without saving 
intermediate results of the excepted instruction on a memory stack. 
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65. (currently amended) The computer of claim 62, further comprising: 
pipeline exception circuitry, designed to recognize an exception occurring in an 

instruction after an earlier a first side-effect of an instruction has been architecturally committed 
and before a later side-effect of the instruction is architecturally committed , and in response, to 
architecturally expose an instruction pointer, contents of a general register file, and contents of 
processor registers to a software exception handler, the processor registers and general purpose 
registers of the computer architecturally exposing sufficient processor state and providing 
sufficient working storage for execution of a software exception handler and resumption of the 
program, without recomputing the earlier first side-effect, and without storing processor state to 
the main memory. 

66. (original) The computer of claim 61 wherein: 

the execution pipeline is a multi-stage execution pipeline; 

the instruction decoder is designed to generate information descriptive of the instructions 
of the first instruction set to be executed by the pipeline, and to store the information into a non- 
pipelined register of the computer; and 

the instruction decoder is designed to determine whether instructions of the first 
instruction set will complete in the pipeline, and to abstain from writing descriptive information 
into the register for instructions following an instruction determined not to complete. 

67. (original) The computer of claim 61, further comprising: 

a software exception handler coded to determine a location of an operand of the 
instruction based on the intra-instruction program counter value. 

68. (currently amended) The computer of claim 61, further comprising: 

pipeline resumption circuitry is designed to restart the excepted instruction recognize an 
exception occurring in a CISC instruction after an earlier a first side-effect of the CISC 
instruction has been architecturally committed and before a later side-effect of the instruction is 
architecturally committed , and thereupon, to architecturally expose an instruction pointer, 
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contents of a general register file, and contents of processor registers to a software exception 
handler, the processor registers and general purpose registers of the computer architecturally 
exposing sufficient processor state and providing sufficient working storage for execution of the 
exception handler and resumption of the program, without recomputing the earlier #h=s* side- 
effect, without storing processor state to the main memory. 

69. (original) The computer of claim 61, wherein the intra-instruction program counter 
value is a serial count of instructions issued by the instruction decoder in response to decoding an 
instruction of the first instruction set. 

70. (original) The computer of claim 61, wherein the intra-instruction program counter 
value has a reserved value to indicate that the instruction decoder is currently in a mode to fetch 
instructions in the second form from a memory of the computer. 

71. (original) The computer of claim 61, further comprising: 

processor registers and control circuitry therefor designed to capture an intermediate state 
of an excepted instruction in sufficient detail for restart of the excepted instruction without 
rerunning the portion of the instruction that completed before the exception, and without the 
intermediate state being spilled to memory. 
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